package cn.iocoder.yudao.module.pay.controller.admin.walletwithdraw.vo;

import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;

import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.util.List;

@Schema(description = "管理后台 - 钱包提现 Response VO")
@Data
@ExcelIgnoreUnannotated
public class PayWalletWithdrawRespVO {

    @Schema(description = "编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "16473")
    @ExcelProperty("编号")
    private Long id;

    @Schema(description = "钱包编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "11374")
    @ExcelProperty("钱包编号")
    private Long walletId;

    @Schema(description = "用户编号", requiredMode = Schema.RequiredMode.REQUIRED, example = "24824")
    @ExcelProperty("用户编号")
    private Long userId;

    @Schema(description = "提现金额", requiredMode = Schema.RequiredMode.REQUIRED, example = "5147")
    @ExcelProperty("提现金额")
    private BigDecimal price;

    @Schema(description = "提现手续费", requiredMode = Schema.RequiredMode.REQUIRED, example = "14929")
    @ExcelProperty("提现手续费")
    private BigDecimal feePrice;

    @Schema(description = "提现类型：2-银行卡；3-微信；4-支付宝", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
    @ExcelProperty("提现类型：2-银行卡；3-微信；4-支付宝")
    private Integer type;

    @Schema(description = "真实姓名", example = "张三")
    @ExcelProperty("真实姓名")
    private String name;

    @Schema(description = "账号")
    @ExcelProperty("账号")
    private String accountNo;

    @Schema(description = "银行名称", example = "芋艿")
    @ExcelProperty("银行名称")
    private String bankName;

    @Schema(description = "开户地址")
    @ExcelProperty("开户地址")
    private String bankAddress;

    @Schema(description = "收款码", example = "https://www.iocoder.cn")
    @ExcelProperty("收款码")
    private String accountQrCodeUrl;

    @Schema(description = "状态：0-审核中，10-审核通过 20-审核不通过；预留：11 - 提现成功；21-提现失败", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
    @ExcelProperty("状态：0-审核中，10-审核通过 20-审核不通过；预留：11 - 提现成功；21-提现失败")
    private Integer status;

    @Schema(description = "审核驳回原因", example = "不对")
    @ExcelProperty("审核驳回原因")
    private String auditReason;

    @Schema(description = "审核时间")
    @ExcelProperty("审核时间")
    private LocalDateTime auditTime;

    @Schema(description = "备注", example = "随便")
    @ExcelProperty("备注")
    private String remark;

    @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("创建时间")
    private LocalDateTime createTime;
    private List<String> payPicUrl;
    private Long adminId;
    private LocalDateTime payTime;
    private BigDecimal payPrice;
    private String bizNo;

}